525.742

SOC FPGA Design Lab

Laboratory 6: Custom AXI / AXIS Peripheral for Processor Interfacing

**Goals**

1. To develop a peripheral which encapsulates your radio design, which uses standard interfaces for easy design re-use in any system
2. To use the new custom peripheral in a PS7-based system
3. To benchmark the performance of that peripheral and determine the bandwidth that we can expect when reading/writing an AXI-lite peripheral.
4. To gain familiarity with the Vivado flow for developing a custom peripheral
5. To use the PS/PL with the PS running Linux

**WARNING : this doesn’t look like a ton of work, but this will take some time to get it right. Do not put this one off and then get frustrated with the tools because you are rushing. It is very easy to get into trouble with the IP packaging flow because it requires that you understand exactly what files you need and how everything fits together.**

Note : The steps in this laboratory assume that you have the Linux boot image on an SD card, and are able to get a shell into the Zybo and connect to it via the network.

**Introduction**

At this point, you have constructed a large portion of the framework for a basic SDR, including selecting a small channel of interesting bandwidth and reducing the data rate to a manageable level. There still remain some pieces to build, but before we do that, we want to capture all of your hard work so that it can be used again, easily, by you or others. The radio you have spent all this time building, is likely not something that is easily moved to another system without effort. This effort would involve lots of configuring of GUI pieces, locating COE files and more. At the completion of this lab, that problem will be solved, all of the signal processing section of your direct-digital-downconverter will be encapsulated in one nice IP block that can be added to any system (and used!) in about 5 minutes.

**References**

In the lecture this week we will discuss packaging IP, both the concepts and the mechanics in Vivado. We will also as a class, construct a custom AXI peripheral. This peripheral (full\_radio) will be a good starting point for the creation of the IP requested in this lab.

**Custom Peripheral**

![](data:image/png;base64,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)The majority of this laboratory revolves around the creation of a custom peripheral, which will be implemented in FPGA fabric and connected to the PS7 CPU via an AXI bus. This peripheral will be the DSP portion of our complete digital downconverter (i.e. not the i2c or DAC interface) and it will have the following interfaces:

* + - 1. AXI-Lite (Slave)
      2. AXI-Stream (Master)
      3. Clk (125MHz in this design), and is the clock for both AXI interfaces
      4. Resetn (active low reset)

Inside the peripheral will be those key pieces of lab 3,4,5 :

1. Lab 3 DDS (the fake-adc, real DDS)
2. Lab 5 Tuner DDS (creates a complex sinusoid for tuning the radio)
3. Lab 5 Mixer (multiplier)
4. Lab 4/5 Filter Chain (filters the tuned signal and reduces the data rate to 48ksps)

The AXI-Stream Master port of the peripheral will contain the output of the second filter as a compliant AXI stream interface (don’t forget the valid!!)

The AXI-Lite Slave port will allow the processor to access 4 registers:

1. Fake\_ADC\_PINC\_Register. This register is at the BASE Address of the peripheral (Peripheral address + 0x00). Writes to this register will set the phase increment of the fake-adc DDS. Reads from this register will return the current phase increment (i.e. what you wrote)
2. Tuner\_PINC\_Register. This register is at BASE+0x04 of the peripheral. Writes to this register will set the phase increment of the tuner DDS. Reads from this register will return the current phase increment (i.e. what you wrote)
3. Control Register. This register is at BASE+0x08 of the peripheral. The only bit implemented in the control register at this time will be reset to the DDS. When bit 0 of this register is ‘1’, the DDS will be in reset. Reads from this register return what was written
4. Timer Register. This register is at address BASE+0x0C of the peripheral. Writing this location will have no effect. Reading this location will return the value of a 32-bit free running counter which is counting clocks.

**Building and Demonstrating the Custom Peripheral**

For this lab, we are going to do something different, and that is to all start with the same base project. As we have briefly discussed in class, though the Vivado GUI is often the best tool for iterative development and experimentation, it is often not the way that large collaborative projects are run. Transferring full projects around is cumbersome, understanding what someone changed from one version to the next is very hard, and intelligent version control is nearly impossible. For that reason, projects are often at least stored and version controlled as scripts (think your VHDL source, and a set of instructions to make the project like “put down this IP, set these parameters, connect this to that…etc.” For this lab, we are going to all gain a little bit of a taste of that by starting with a project which uses that configuration. Now that you understand what is going on behind the scenes (because you’ve done it yourself many times) the automated version may seem even more helpful.

The project repository is located for your retrieval at <https://github.com/dougwen/radio_periph_lab.git> . If you have a git client on your machine, clone the repository, or you can navigate to that location and grab the archive itself. Notice first that the entire project is very small, and is entirely text files that are ideal for version control. *IMPORTANT : if you download this repository as a zip file, it will include a “-“ character since github names the archives as repositoryname-branch. You will definitely want to change the name so you don’t have a “-“ in your project path.*

In the repository, a few scripts are visible. In windows you can just double-click on the “make\_project.bat” file, in Linux, execute “make\_project.sh” from the command line. This script will:

* + Construct the vivado project
  + Add sources to the project
  + Draw the block diagram and set all the IP settings
  + Synthesize, Place + Route the design
  + Generate a bitfile
  + Note that we can also script the generation of a vitis project and BOOT.bin, but we won’t be using that flow for this lab. If you are looking at make\_project.bat or make\_project.sh, you can see the steps necessary to do all of this.

Note that the newly generated vivado project is in the “vivado” directory. This project is in the structure you are familiar with, and can be edited and used in the GUI. Also, the entire vivado project can easily be deleted and then regenerated if you like. This project is configured to use an ip repository named “ip\_repo” which is at the base level of the directory you cloned. That ip\_repository has two pieces of IP in it: lowlevel-dac-interface, and a new peripheral (the one we started in class) named full\_radio.

Lets explore around a little bit before we embark on any changes. Open up the newly created project in vivado, and check out the block diagram. Note that the low-level-dac interface and the full\_radio peripherals are instantiated in your block diagram as IP. The “full\_radio” is not complete of course, but it does have some working pieces, namely our “Fake ADC” DDS, who’s phase increment is controlled by a register at the base address of the peripheral, another register which always reads back 0xDEADBEEF(this is at address BASE+0x04), and 2 more registers locations that can be written and read back, so before we change it, lets make sure that it works.

1. First, if you haven’t already, configure the codec by loading the instructor bitfile “configure\_codec.bit.bin” into the PL. In case you’ve forgotten, this is done by typing fpgautil -b path\_to\_bitfile. At this point a tone should be coming out the headphones. We are done with that bitfile now, it only had one job ☺
2. Using scp or MobaXterm transfer the newly created bitfile to the zybo (design\_1\_wrapper.bit.bin is in the impl\_1 directory of your vivado project, just like a normal bitfile would be)
3. program the bitfile into the PL : type “fpgautil -b design\_1\_wrapper.bit.bin”
4. now, changing the DDS phase increment is as simple as a single memory write. We can do this from the command-line using devmem a command line tool for accessing physical memory. Lets write the value 1000 to the phase increment : **devmem 0x43c00000 w 1000. You should hear the tone at ~931Hz**
5. Lets also read the value of the next register, where we expect to see 0xDEADBEEF **devmem 0x43c00004 w**

So, it looks like our full\_radio peripheral works as designed, now it is time to actually turn it into the full radio!

Once you verified you have a known good starting point, you will want to edit the full\_radio peripheral to actually include the rest of our radio. **Edit in IP Packager** the full\_radio peripheral, to add all of the pieces that you have now mastered from lab 3,4,5. Once you have finished, be sure to **repackage** the IP.

HINT: don’t actually click Package until you have green checkmarks for all of the steps. Address any warnings which come up during the packaging step – they likely can not be ignored safely.

HINT: when you package the IP, let it create an archive of the IP for you. In that zip file will be only the files that are needed for the IP, and nothing else. Useful to have if you accidentally clutter up the ip directory with a bunch of other files some way or another.

Once you have repackaged the IP, you should be prompted to update the IP in your base design; however if not, be sure to run “Report IP Status” to start the update process. Since this is the only part of the design that needs to be changed, you can now rebuild the entire design to the bitfile stage. With this bitfile programmed into the PL, the PS will be able to control tuning and frequency by register writes. Note that the project has a system ILA in it which you can use to observe both the AXI transactions to the custom peripheral, and the AXI-S data flow from the custom peripheral. Once your bitfile has been created, lets test it out, first interactively:

1. Make the .bit.bin file, transfer it to the zybo, and load it with fpgautil.
2. Is the counter present ? Run this line a couple times and see if the value is incrementing : **devmem 0x43c0000c w**
3. Set the tuner DDS phase increment to 30000000 : **devmem 0x43c00004 w 30000000**
4. Set the fake ADC to phase increment 30001000 : **devmem 0x43c00000 w 30001000**

If the results are expected, it is time to run the full test suite. Part of the repository (under src/linux\_software) is a C program named test\_radio.c can be used to test the radio.

1. Edit the test\_radio.c file to print your name at the beginning of main()
2. Edit the test\_radio.c file to change the print\_benchmark function to actually compute the actual read-speed in **Megabytes/second**
3. Transfer the test\_radio.c file to the Zybo if you haven’t already
4. Compile the code : **gcc test\_radio.c -o test\_radio**
5. Execute the code : **./test\_radio**

The test radio code tunes the radio to 30MHz, and then plays a little test song by injecting tones near 30MHz into the radio from the fake adc. Finally. the program will then do a benchmarking loop, whereby it uses the timer register to measure how many clocks it takes to transfer a fixed amount of data through the peripheral. It reads the timer 2048 times. The number of clocks that has elapsed between the first and last reads can tell you exactly how much data the processor can read from a peripheral using this method. This is an important number – because it determines the types of things that we can do with this type of peripheral.

**What to Turn In**

1. Your entire project packaged as a script, just like you received it. Attach a zip file to the submission which should not include the generated vitis or vivado directories. I should be able to take your directory and run it all the way to the point of generating a .bit.bin that I can use for testing. *Though it isn’t required,* 10 bonus points are given for skipping the zip file and locating it in a git-repo where I can clone it. The way I imagine this, the only things that change from the project you grabbed are:
   1. Some changes and new files in the ip\_repo/full\_radio folder. Note, if this is MegaBytes in size, you’ve likely done something wrong.
   2. Test\_radio.c now has your name in it, and has your code for calculating throughput in MegaBytes/second
2. A short video which shows the program executing on your Zybo. Make sure that the result you measured for the data rate from the peripheral (in Mbytes/sec) is visible on the video, and that I can hear that beautiful song playing in the background… does it sound familiar to any of you?
3. Clone the repository
4. Execute “construct\_project.bat” or “construct\_project.sh”, this will make a new directory (“vivado”) with a complete vivado project in it. This project will contain the PS, an ILA, the lowlevel\_dac\_interface, and a skeleton radio\_peripheral, the one we worked on in class.
5. Open the project in vivado to see the design. As mentioned, this design already contains a custom peripheral which is the starting point for your complete radio peripheral. Right click on it, and “Edit in IP Packager” to edit your IP and make it how you want.
6. After transferring all of your DDC from lab5 into the peripheral, repackage it
7. Update the bd (report ip status)
8. Make a bitfile (either manually in the gui ,or by running impl\_project,bat (or impl\_oroject.sh for linux users)

At this point, your hardware is complete, and it is time to test the peripheral with some software. This time, instead of exporting to Vitis and writing software that way, we will be running some software